home *** CD-ROM | disk | FTP | other *** search
/ ADA Programming Guide / ADA Programming Guide.iso / adatutor / lrmrdr / chap01.doc < prev    next >
Text File  |  1996-01-30  |  28KB  |  990 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6. The following document is a draft  of  the  corresponding  chapter  of  the
  7. version  of  the  Ada  Reference  Manual  produced  in response to the Ansi
  8. Canvass.  It is given a limited circulation  to  Ada  implementers  and  to
  9. other groups contributing comments (according to the conventions defined in
  10. RRM.comments).  This draft should not be referred to in any publication.
  11.  
  12.  
  13.  
  14.                       ANSI-RM-01.v23 - Draft Chapter
  15.  
  16.                               1  Introduction
  17.                                 version 23
  18.  
  19.                                  83-02-11
  20.  
  21. This version has addressed comments up to #5795
  22.  
  23.  
  24.  
  25.  
  26.  
  27.  
  28.  
  29.  
  30.  
  31.  
  32.  
  33.  
  34.  
  35.  
  36.  
  37.  
  38.  
  39.  
  40.  
  41.  
  42.  
  43.  
  44.  
  45.  
  46.  
  47.  
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54.  
  55.  
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.  
  64.  
  65.  
  66.  
  67.  
  68.  
  69.  
  70.  
  71.  
  72.  
  73.  
  74.  
  75.  
  76.  
  77. >                               1. Introduction
  78.  
  79.  
  80.  
  81. Ada  is  a  programming  language  designed in accordance with requirements
  82. defined by the United States Department of Defense:  the so-called Steelman
  83. requirements.   Overall,  these  requirements  call  for  a  language  with
  84. considerable  expressive  power  covering  a wide application domain.  As a
  85. result, the language includes facilities  offered  by  classical  languages
  86. such  as  Pascal  as  well  as  facilities  often found only in specialized
  87. languages.  Thus the language is a modern  algorithmic  language  with  the
  88. usual  control  structures,  and  with  the  ability  to  define  types and
  89. subprograms.  It also serves the need for modularity, whereby data,  types,
  90. and  subprograms  can  be  packaged.   It treats modularity in the physical
  91. sense as well, with a facility to support separate compilation.
  92.  
  93. In addition to these aspects, the language  covers  real-time  programming,
  94. with  facilities to model parallel tasks and to handle exceptions.  It also
  95. covers  systems  programming;   this  requires  precise  control  over  the
  96. representation of data and access to system-dependent properties.  Finally,
  97. both application-level and machine-level input-output are defined.
  98.  
  99.  
  100.  
  101. > 1.1  Scope of the Standard
  102.  
  103.  
  104. This  standard  specifies  the form and meaning of program units written in
  105. Ada.  Its purpose is to promote  the  portability  of  Ada  programs  to  a
  106. variety of data processing systems.
  107.  
  108.  
  109.  
  110. > 1.1.1  Extent of the Standard
  111.  
  112.  
  113. This standard specifies:
  114.  
  115. (a)  The form of a program unit written in Ada.
  116.  
  117. (b)  The effect of translating and executing such a program unit.
  118.  
  119. (c)  The manner in  which  program  units  may  be  combined  to  form  Ada
  120.      programs.
  121.  
  122. (d)  The predefined program units that  a  conforming  implementation  must
  123.      supply.
  124.  
  125. (e)  The permissible variations within the  standard,  and  the  manner  in
  126.      which they must be specified.
  127.  
  128. (f)  Those violations of the standard that a conforming  implementation  is
  129.      required  to  detect,  and  the  effect  of attempting to translate or
  130.      execute a program unit containing such violations.
  131.  
  132. (g)  Those violations of the standard that a conforming  implementation  is
  133.      not required to detect.
  134.  
  135.  
  136.  
  137.  
  138.  
  139.  
  140.  
  141.  
  142.  
  143.  
  144.  
  145.  
  146.  
  147.  
  148.  
  149.  
  150.  
  151.  
  152.  
  153.  
  154.  
  155.  
  156.  
  157.  
  158.  
  159.  
  160.  
  161.  
  162.  
  163.  
  164.  
  165.  
  166.  
  167.  
  168.  
  169.  
  170.  
  171.  
  172.  
  173.  
  174.  
  175.  
  176.  
  177.  
  178.  
  179.  
  180.  
  181.  
  182.  
  183.  
  184.  
  185.  
  186.  
  187.  
  188.  
  189.  
  190.  
  191.  
  192.  
  193. This standard does not specify:
  194.  
  195. (h)  The means whereby a program unit written in Ada  is  transformed  into
  196.      object code executable by a processor.
  197.  
  198. (i)  The means whereby translation or execution of program units is invoked
  199.      and the executing units are controlled.
  200.  
  201. (j)  The size or speed of the object code, or the relative execution  speed
  202.      of different language constructs.
  203.  
  204. (k)  The form or contents of any listings produced by implementations;   in
  205.      particular, the form or contents of error or warning messages.
  206.  
  207. (l)  The effect of executing a program unit  that  contains  any  violation
  208.      that a conforming implementation is not required to detect.
  209.  
  210. (m)  The size of a program or program unit that will exceed the capacity of
  211.      a particular conforming implementation.
  212.  
  213. Where  this  standard  specifies  that a program unit written in Ada has an
  214. exact effect, this effect is the operational meaning of  the  program  unit
  215. and  must  be  produced  by  all  conforming  implementations.   Where this
  216. standard specifies permissible variations in the effects of constituents of
  217. a program unit written in Ada, the operational meaning of the program  unit
  218. as  a  whole  is understood to be the range of possible effects that result
  219. from all these variations, and a conforming implementation  is  allowed  to
  220. produce  any of these possible effects.  Examples of permissible variations
  221. are:
  222.  
  223.   -  The represented values of fixed or floating  numeric  quantities,  and
  224.      the results of operations upon them.
  225.  
  226.   -  The order of execution of statements in different parallel  tasks,  in
  227.      the absence of explicit synchronization.
  228.  
  229.  
  230.  
  231. > 1.1.2  Conformity of an Implementation With the Standard
  232.  
  233.  
  234. A conforming implementation is one that:
  235.  
  236. (a)  Correctly translates and executes legal program units written in  Ada,
  237.      provided  that  they are not so large as to exceed the capacity of the
  238.      implementation.
  239.  
  240. (b)  Rejects all program units that are so large as to exceed the  capacity
  241.      of the implementation.
  242.  
  243. (c)  Rejects all program units  that  contain  errors  whose  detection  is
  244.      required by the standard.
  245.  
  246. (d)  Supplies all predefined program units required by the standard.
  247.  
  248. (e)  Contains no variations except where the standard permits.
  249.  
  250. (f)  Specifies all such permitted variations in the  manner  prescribed  by
  251.      the standard.
  252.  
  253.  
  254.  
  255.  
  256.  
  257.  
  258.  
  259.  
  260.  
  261.  
  262.  
  263.  
  264.  
  265.  
  266.  
  267.  
  268.  
  269.  
  270.  
  271.  
  272.  
  273.  
  274.  
  275.  
  276.  
  277.  
  278.  
  279.  
  280.  
  281.  
  282.  
  283.  
  284.  
  285.  
  286.  
  287.  
  288.  
  289.  
  290.  
  291.  
  292.  
  293.  
  294.  
  295.  
  296.  
  297.  
  298.  
  299.  
  300.  
  301.  
  302.  
  303.  
  304.  
  305.  
  306.  
  307.  
  308.  
  309.  
  310.  
  311.  
  312.  
  313. > 1.2  Structure of the Standard
  314.  
  315.  
  316. This  reference  manual  contains  fourteen  chapters, three annexes, three
  317. appendices, and an index.
  318.  
  319. Each chapter is divided into sections that have a common  structure.   Each
  320. section  introduces  its  subject,  gives  any  necessary syntax rules, and
  321. describes the semantics of the corresponding language constructs.  Examples
  322. and notes, and then references, may appear at the end of a section.
  323.  
  324. Examples are meant to illustrate  the  possible  forms  of  the  constructs
  325. described.   Notes  are  meant  to  emphasize  consequences  of  the  rules
  326. described in the section or elsewhere.  References are meant to attract the
  327. attention of readers to a term or phrase having a technical meaning defined
  328. in another section.
  329.  
  330. The standard definition of the Ada programming  language  consists  of  the
  331. fourteen   chapters  and  the  three  annexes,  subject  to  the  following
  332. restriction:   the  material  in  each  of  the  items  listed   below   is
  333. informative, and not part of the standard definition of the Ada programming
  334. language:
  335.  
  336.   -  Section 1.3 Design goals and sources
  337.  
  338.   -  Section 1.4 Language summary
  339.  
  340.   -  The examples, notes, and references given at the end of each section
  341.  
  342.   -  Each section whose title starts with the word "Example" or  "Examples"
  343.  
  344.  
  345.  
  346. > 1.3  Design Goals and Sources
  347.  
  348.  
  349. Ada  was  designed with three overriding concerns:  program reliability and
  350. maintenance, programming as a human activity, and efficiency.
  351.  
  352. The need for languages that promote reliability and simplify maintenance is
  353. well established.  Hence emphasis was placed on  program  readability  over
  354. ease  of  writing.   For  example,  the  rules of the language require that
  355. program variables be explicitly declared and that their type be  specified.
  356. Since  the  type  of  a  variable  is  invariant, compilers can ensure that
  357. operations on variables are compatible with  the  properties  intended  for
  358. objects of the type.  Furthermore, error-prone notations have been avoided,
  359. and  the syntax of the language avoids the use of encoded forms in favor of
  360. more English-like constructs.  Finally, the  language  offers  support  for
  361. separate  compilation  of  program  units in a way that facilitates program
  362. development and maintenance, and which provides the same degree of checking
  363. between units as within a unit.
  364.  
  365. Concern for the human programmer  was  also  stressed  during  the  design.
  366. Above  all,  an attempt was made to keep the language as small as possible,
  367. given the ambitious nature of the application domain.  We have attempted to
  368. cover this domain with a small number of underlying concepts integrated  in
  369. a  consistent  and systematic way.  Nevertheless we have tried to avoid the
  370. pitfalls of excessive involution, and in the constant  search  for  simpler
  371. designs  we  have  tried  to  provide  language  constructs that correspond
  372. intuitively to what the users will normally expect.
  373.  
  374. Like many other human activities, the development of programs  is  becoming
  375. ever  more  decentralized  and  distributed.   Consequently, the ability to
  376. assemble a program from independently produced software components has been
  377. a central idea in this design.  The concepts of packages, of private types,
  378. and of  generic  units  are  directly  related  to  this  idea,  which  has
  379. ramifications in many other aspects of the language.
  380.  
  381.  
  382.  
  383.  
  384.  
  385.  
  386.  
  387.  
  388.  
  389.  
  390.  
  391.  
  392.  
  393.  
  394.  
  395.  
  396.  
  397.  
  398.  
  399.  
  400.  
  401.  
  402.  
  403.  
  404.  
  405.  
  406.  
  407.  
  408.  
  409.  
  410.  
  411.  
  412.  
  413.  
  414.  
  415.  
  416.  
  417.  
  418.  
  419.  
  420.  
  421.  
  422.  
  423.  
  424.  
  425.  
  426.  
  427.  
  428.  
  429.  
  430.  
  431.  
  432.  
  433. No  language  can  avoid the problem of efficiency.  Languages that require
  434. over-elaborate compilers, or that lead to the inefficient use of storage or
  435. execution time, force these inefficiencies  on  all  machines  and  on  all
  436. programs.   Every  construct  of  the language was examined in the light of
  437. present  implementation   techniques.    Any   proposed   construct   whose
  438. implementation was unclear or that required excessive machine resources was
  439. rejected.
  440.  
  441. None of the above design goals was considered as achievable after the fact.
  442. The design goals drove the entire design process from the beginning.
  443.  
  444. A  perpetual  difficulty  in language design is that one must both identify
  445. the capabilities required by the application  domain  and  design  language
  446. features  that  provide these capabilities.  The difficulty existed in this
  447. design, although to a lesser degree than  usual  because  of  the  Steelman
  448. requirements.   These  requirements  often simplified the design process by
  449. allowing it to concentrate on the design of a given system providing a well
  450. defined  set  of  capabilities,  rather  than  on  the  definition  of  the
  451. capabilities themselves.
  452.  
  453. Another significant simplification of the design work resulted from earlier
  454. experience acquired by several successful Pascal derivatives developed with
  455. similar goals.  These are the languages Euclid, Lis, Mesa, Modula, and Sue.
  456. Many of the key ideas and syntactic forms developed in these languages have
  457. counterparts  in  Ada.   Several  existing  languages  such as Algol 68 and
  458. Simula, and also  recent  research  languages  such  as  Alphard  and  Clu,
  459. influenced  this  language in several respects, although to a lesser degree
  460. than did the Pascal family.
  461.  
  462. Finally, the evaluation reports received on  an  earlier  formulation  (the
  463. Green  language),  and  on alternative proposals (the Red, Blue, and Yellow
  464. languages), the language reviews that took place  at  different  stages  of
  465. this project, and the thousands of comments received from fifteen different
  466. countries  during  the  preliminary stages of the Ada design and during the
  467. ANSI canvass, all had a significant impact on the  standard  definition  of
  468. the language.
  469.  
  470.  
  471.  
  472. > 1.4  Language Summary
  473.  
  474.  
  475. An  Ada  program  is  composed of one or more program units.  These program
  476. units can be compiled separately.  Program units may be subprograms  (which
  477. define  executable  algorithms), package units (which define collections of
  478. entities), task units (which  define  parallel  computations),  or  generic
  479. units  (which  define  parameterized  forms  of  packages and subprograms).
  480. Each unit normally consists of two parts:  a specification, containing  the
  481. information that must be visible to other units, and a body, containing the
  482. implementation details, which need not be visible to other units.
  483.  
  484. This  distinction of the specification and body, and the ability to compile
  485. units separately, allows a program to be designed, written, and tested as a
  486. set of largely independent software components.
  487.  
  488. An Ada program will normally make use of a  library  of  program  units  of
  489. general   utility.    The   language   provides  means  whereby  individual
  490. organizations can construct their own libraries.  The text of a  separately
  491. compiled program unit must name the library units it requires.
  492.  
  493. Program Units
  494.  
  495. A  subprogram is the basic unit for expressing an algorithm.  There are two
  496. kinds of subprograms:  procedures and functions.  A procedure is the  means
  497. of  invoking  a  series  of actions.  For example, it may read data, update
  498. variables, or produce some output.  It may have parameters,  to  provide  a
  499. controlled means of passing information between the procedure and the point
  500. of call.
  501.  
  502.  
  503.  
  504.  
  505.  
  506.  
  507.  
  508.  
  509.  
  510.  
  511.  
  512.  
  513.  
  514.  
  515.  
  516.  
  517.  
  518.  
  519.  
  520.  
  521.  
  522.  
  523.  
  524.  
  525.  
  526.  
  527.  
  528.  
  529.  
  530.  
  531.  
  532.  
  533.  
  534.  
  535.  
  536.  
  537.  
  538.  
  539.  
  540.  
  541.  
  542.  
  543.  
  544.  
  545.  
  546.  
  547.  
  548.  
  549.  
  550.  
  551.  
  552.  
  553. A  function  is  the  means  of invoking the computation of a value.  It is
  554. similar to a procedure, but in addition will return a result.
  555.  
  556. A package is the basic unit for defining a collection of logically  related
  557. entities.   For  example,  a package can be used to define a common pool of
  558. data and types, a collection of related  subprograms,  or  a  set  of  type
  559. declarations  and  associated  operations.   Portions  of  a package can be
  560. hidden from the user, thus allowing access only to the  logical  properties
  561. expressed by the package specification.
  562.  
  563. A task unit is the basic unit for defining a task whose sequence of actions
  564. may  be  executed in parallel with those of other tasks.  Such tasks may be
  565. implemented  on  multicomputers,  multiprocessors,  or   with   interleaved
  566. execution  on  a  single processor.  A task unit may define either a single
  567. executing task or a task type permitting the  creation  of  any  number  of
  568. similar tasks.
  569.  
  570. Declarations and Statements
  571.  
  572. The  body  of  a  program unit generally contains two parts:  a declarative
  573. part, which defines the logical entities to be used in  the  program  unit,
  574. and  a  sequence  of statements, which defines the execution of the program
  575. unit.
  576.  
  577. The declarative part associates names with declared entities.  For example,
  578. a name may denote a type, a constant,  a  variable,  or  an  exception.   A
  579. declarative  part  also introduces the names and parameters of other nested
  580. subprograms, packages, task units, and generic units  to  be  used  in  the
  581. program unit.
  582.  
  583. The  sequence  of statements describes a sequence of actions that are to be
  584. performed.  The statements are executed  in  succession  (unless  an  exit,
  585. return, or goto statement, or the raising of an exception, causes execution
  586. to continue from another place).
  587.  
  588. An  assignment statement changes the value of a variable.  A procedure call
  589. invokes execution of a procedure after associating  any  actual  parameters
  590. provided at the call with the corresponding formal parameters.
  591.  
  592. Case  statements  and  if  statements  allow  the  selection of an enclosed
  593. sequence of statements based on the value of an expression or on the  value
  594. of a condition.
  595.  
  596. The  loop statement provides the basic iterative mechanism in the language.
  597. A loop statement specifies that a sequence of statements is to be  executed
  598. repeatedly  as  directed by an iteration scheme, or until an exit statement
  599. is encountered.
  600.  
  601. A block statement comprises  a  sequence  of  statements  preceded  by  the
  602. declaration of local entities used by the statements.
  603.  
  604. Certain  statements are only applicable to tasks.  A delay statement delays
  605. the execution of a task for a specified duration.  An entry call  statement
  606. is  written  as  a  procedure  call  statement;  it specifies that the task
  607. issuing the call is ready for a rendezvous with another task that has  this
  608. entry.   The  called  task  is  ready  to  accept  the  entry call when its
  609. execution reaches a corresponding accept  statement,  which  specifies  the
  610. actions then to be performed.  After completion of the rendezvous, both the
  611. calling  task and the task having the entry may continue their execution in
  612. parallel.  One form of the select statement allows a selective wait for one
  613. of several alternative rendezvous.  Other forms  of  the  select  statement
  614. allow conditional or timed entry calls.
  615.  
  616.  
  617.  
  618.  
  619.  
  620.  
  621.  
  622.  
  623.  
  624.  
  625.  
  626.  
  627.  
  628.  
  629.  
  630.  
  631.  
  632.  
  633.  
  634.  
  635.  
  636.  
  637.  
  638.  
  639.  
  640.  
  641.  
  642.  
  643.  
  644.  
  645.  
  646.  
  647.  
  648.  
  649.  
  650.  
  651.  
  652.  
  653.  
  654.  
  655.  
  656.  
  657.  
  658.  
  659.  
  660.  
  661.  
  662.  
  663.  
  664.  
  665.  
  666.  
  667.  
  668.  
  669.  
  670.  
  671.  
  672.  
  673. Execution  of a program unit may encounter error situations in which normal
  674. program execution cannot continue.  For example, an arithmetic  computation
  675. may exceed the maximum allowed value of a number, or an attempt may be made
  676. to  access  an  array component by using an incorrect index value.  To deal
  677. with such error situations,  the  statements  of  a  program  unit  can  be
  678. textually  followed  by  exception  handlers that specify the actions to be
  679. taken when the error situation arises.  Exceptions can be raised explicitly
  680. by a raise statement.
  681.  
  682. Data Types
  683.  
  684. Every object in the language has a  type,  which  characterizes  a  set  of
  685. values  and  a set of applicable operations.  The main classes of types are
  686. scalar types (comprising enumeration and numeric types),  composite  types,
  687. access types, and private types.
  688.  
  689. An  enumeration  type  defines  an  ordered  set  of  distinct  enumeration
  690. literals, for example a list of states or an alphabet of  characters.   The
  691. enumeration types BOOLEAN and CHARACTER are predefined.
  692.  
  693. Numeric  types provide a means of performing exact or approximate numerical
  694. computations.  Exact computations use integer types, which denote  sets  of
  695. consecutive  integers.   Approximate  computations  use  either fixed point
  696. types, with absolute bounds on the error, or  floating  point  types,  with
  697. relative  bounds  on  the  error.   The  numeric  types INTEGER, FLOAT, and
  698. DURATION are predefined.
  699.  
  700. Composite types  allow  definitions  of  structured  objects  with  related
  701. components.   The  composite  types  in the language provide for arrays and
  702. records.  An array is an object with indexed components of the  same  type.
  703. A  record  is  an object with named components of possibly different types.
  704. The array type STRING is predefined.
  705.  
  706. A record may have special  components  called  discriminants.   Alternative
  707. record structures that depend on the values of discriminants can be defined
  708. within a record type.
  709.  
  710. Access  types  allow  the construction of linked data structures created by
  711. the evaluation of allocators.  They allow several variables  of  an  access
  712. type  to  designate  the  same  object,  and  components  of  one object to
  713. designate the same or other objects.  Both the elements in  such  a  linked
  714. data  structure  and their relation to other elements can be altered during
  715. program execution.
  716.  
  717. Private types can be defined in a package that conceals structural  details
  718. that  are  externally  irrelevant.  Only the logically necessary properties
  719. (including any discriminants) are made visible to the users of such  types.
  720.  
  721. The  concept  of  a  type is refined by the concept of a subtype, whereby a
  722. user can constrain the set of allowed values of a type.   Subtypes  can  be
  723. used  to  define  subranges  of  scalar types, arrays with a limited set of
  724. index values, and records and private types  with  particular  discriminant
  725. values.
  726.  
  727.  
  728.  
  729.  
  730.  
  731.  
  732.  
  733.  
  734.  
  735.  
  736.  
  737.  
  738. Other Facilities
  739.  
  740. Representation clauses can be used to specify the mapping between types and
  741. features  of an underlying machine.  For example, the user can specify that
  742. objects of a given type must be represented with a given number of bits, or
  743. that the components of a record are to be represented using a given storage
  744. layout.  Other features allow the controlled use of low level, nonportable,
  745. or implementation-dependent aspects,  including  the  direct  insertion  of
  746. machine code.
  747.  
  748. Input-output  is  defined  in  the  language by means of predefined library
  749. packages.   Facilities  are  provided  for  input-output   of   values   of
  750. user-defined   as   well   as  of  predefined  types.   Standard  means  of
  751. representing values in display form are also provided.
  752.  
  753.  
  754.  
  755.  
  756.  
  757.  
  758.  
  759.  
  760.  
  761.  
  762.  
  763.  
  764.  
  765.  
  766.  
  767.  
  768.  
  769.  
  770.  
  771.  
  772.  
  773.  
  774.  
  775.  
  776.  
  777.  
  778.  
  779.  
  780.  
  781.  
  782.  
  783.  
  784.  
  785.  
  786.  
  787.  
  788.  
  789.  
  790.  
  791.  
  792.  
  793.  
  794.  
  795.  
  796.  
  797.  
  798.  
  799.  
  800.  
  801.  
  802.  
  803. Finally, the language provides a  powerful  means  of  parameterization  of
  804. program units, called generic program units.  The generic parameters can be
  805. types  and subprograms (as well as objects) and so allow general algorithms
  806. to be applied to all types of a given class.
  807.  
  808.  
  809.  
  810. > 1.5  Method of Description and Syntax Notation
  811.  
  812.  
  813. The form of Ada program units is  described  by  means  of  a  context-free
  814. syntax  together with context-dependent requirements expressed by narrative
  815. rules.
  816.  
  817. The meaning of Ada program units is described by means of  narrative  rules
  818. defining  both  the effects of each construct and the composition rules for
  819. constructs.   This  narrative  employs  technical   terms   whose   precise
  820. definition  is  given in the text (references to the section containing the
  821. definition of a technical term appear at the end of each section that  uses
  822. the term).
  823.  
  824. All other terms are in the English language and bear their natural meaning,
  825. as  defined  in Webster's Third New International Dictionary of the English
  826. Language.
  827.  
  828.  
  829. The context-free syntax of the language is described using a simple variant
  830. of Backus-Naur-Form.  In particular,
  831.  
  832. (a)  Lower case words, some containing embedded  underlines,  are  used  to
  833.      denote syntactic categories, for example:
  834.  
  835.           adding_operator
  836.  
  837.  
  838.      Whenever the name of a syntactic  category  is  used  apart  from  the
  839.      syntax  rules  themselves,  spaces  take  the  place of the underlines
  840.      (thus:  adding operator).
  841.  
  842. (b)  Boldface words are used to denote reserved words, for example:
  843.  
  844.           array
  845.  
  846.  
  847. (c)  Square brackets enclose optional items.  Thus the two following  rules
  848.      are equivalent.
  849.  
  850.           return_statement ::= return [expression];
  851.           return_statement ::= return; | return expression;
  852.  
  853.  
  854. (d)  Braces enclose a repeated item.  The item  may  appear  zero  or  more
  855.      times;  the repetitions occur from left to right as with an equivalent
  856.      left-recursive rule.  Thus the two following rules are equivalent.
  857.  
  858.           term ::= factor {multiplying_operator factor}
  859.           term ::= factor | term multiplying_operator factor
  860.  
  861. (e)  A  vertical  bar  separates  alternative  items   unless   it   occurs
  862.      immediately  after  an  opening  brace,  in  which  case it stands for
  863.      itself:
  864.  
  865.           letter_or_digit ::= letter | digit
  866.           component_association ::= [choice {| choice} =>] expression
  867.  
  868.  
  869. (f)  If the name of any syntactic category starts with an italicized  part,
  870.      it  is  equivalent  to  the category name without the italicized part.
  871.      The italicized part is intended to convey some  semantic  information.
  872.      For example type_name and task_name are both equivalent to name alone.
  873.  
  874. Note:
  875.  
  876. The  syntax  rules describing structured constructs are presented in a form
  877. that corresponds to the  recommended  paragraphing.   For  example,  an  if
  878. statement is defined as
  879.  
  880.     if_statement ::=
  881.         if condition then
  882.           sequence_of_statements
  883.        {elsif condition then
  884.           sequence_of_statements}
  885.        [else
  886.           sequence_of_statements]
  887.         end if;
  888.  
  889. Different  lines  are  used for parts of a syntax rule if the corresponding
  890. parts of the construct  described  by  the  rule  are  intended  to  be  on
  891. different   lines.   Indentation  in  the  rule  is  a  recommendation  for
  892. indentation of the corresponding part of the construct.  It is  recommended
  893. that  all  indentations be by multiples of a basic step of indentation (the
  894. number of spaces for the basic step is not defined).  The preferred  places
  895. for  other  line  breaks  are  after  semicolons.   On the other hand, if a
  896. complete construct can fit on  one  line,  this  is  also  allowed  in  the
  897. recommended paragraphing.
  898.  
  899.  
  900.  
  901. > 1.6  Classification of Errors
  902.  
  903.  
  904. The   language   definition   classifies   errors  into  several  different
  905. categories:
  906.  
  907. (a)  Errors that  must  be  detected  at  compilation  time  by  every  Ada
  908.      compiler.
  909.  
  910.      These  errors  correspond  to  any  violation  of a rule given in this
  911.      reference manual, other than the violations that correspond to (b)  or
  912.      (c)  below.   In particular, violation of any rule that uses the terms
  913.      must, allowed, legal,  or  illegal  belongs  to  this  category.   Any
  914.      program  that  contains  such an error is not a legal Ada program;  on
  915.      the other hand, the fact that a program is legal does  not  mean,  per
  916.      se, that the program is free from other forms of error.
  917.  
  918. (b)  Errors that must be detected at run time by the execution  of  an  Ada
  919.      program.
  920.  
  921.      The  corresponding  error  situations are associated with the names of
  922.      the predefined exceptions.  Every Ada compiler is required to generate
  923.      code  that  raises  the  corresponding  exception  if  such  an  error
  924.      situation arises during program execution.  If an exception is certain
  925.      to  be  raised  in  every  execution  of a program, then compilers are
  926.      allowed (although not required) to report  this  fact  at  compilation
  927.      time.
  928.  
  929. (c)  Erroneous execution.
  930.  
  931.      The language rules specify certain rules to be obeyed by Ada programs,
  932.      although  there is no requirement on Ada compilers to provide either a
  933.      compilation-time or a run-time detection  of  the  violation  of  such
  934.      rules.   The  errors  of this category are indicated by the use of the
  935.      word  erroneous  to  qualify  the  execution  of   the   corresponding
  936.      constructs.  The effect of erroneous execution is unpredictable.
  937.  
  938. (d)  Incorrect order dependences.
  939.  
  940.      Whenever  the  reference  manual  specifies  that different parts of a
  941.      given construct are to be executed in some order that is  not  defined
  942.      by  the  language,  this  means  that the implementation is allowed to
  943.      execute these parts in any  given  order,  following  the  rules  that
  944.      result  from  that given order, but not in parallel.  Furthermore, the
  945.      construct is incorrect if execution of  these  parts  in  a  different
  946.      order  would  have  a different effect.  Compilers are not required to
  947.      provide either compilation-time or  run-time  detection  of  incorrect
  948.      order dependences.  The foregoing is expressed in terms of the process
  949.      that  is  called  execution;  it applies equally to the processes that
  950.      are called evaluation and elaboration.
  951.  
  952. If a compiler is able to recognize at compilation time that a construct  is
  953. erroneous  or  contains an incorrect order dependence, then the compiler is
  954. allowed to generate, in place of  the  code  otherwise  generated  for  the
  955. construct,   code  that  raises  the  predefined  exception  PROGRAM_ERROR.
  956. Similarly, compilers are allowed to generate code that checks at  run  time
  957. for  erroneous  constructs,  for  incorrect order dependences, or for both.
  958. The predefined exception PROGRAM_ERROR is raised if such a check fails.
  959.  
  960.  
  961.  
  962.  
  963.  
  964.  
  965.  
  966.  
  967.  
  968.  
  969.  
  970.  
  971.  
  972.  
  973.  
  974.  
  975.  
  976.  
  977.  
  978.  
  979.  
  980.  
  981.  
  982.  
  983.  
  984.  
  985.  
  986.  
  987.  
  988.  
  989.  
  990.